**A GENERAL PURPOSE REAL-TIME SoC BASED MATRIX CALCULATOR**

**Project**

**ECE 5730 –Embedded System Design Using FPGAs**

**Submitted by**

**Cory Ness**

**Kokila Subramanian**

**Shivani Devatha**

**Submitted to**

**Professor Subramaniam Ganesan**

![Oakland University on Twitter: &quot;The OU leadership team has decided to  mandate wearing face masks inside all buildings, effective Thursday, August  5. Visit https://t.co/EN03cVFg7o for more information.&quot;](data:image/jpeg;base64,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rSupmwAAAAgAHIvhEOgBjYDBDaX4i/CNv1KONPH2TRgmwCgi12uwWrWjepFRds+1Q9rHfacgUgAaIEfMscMzgBSTYxUjMoa7h9Cjb9SjjhHEhQluhueR/ZkR/DSyjK0W+1Q9rHfYXqXoBUtZQWToLnREtDAVqi7c/Ao2/Uo49JStmu9mBBCiTswBwGSu2HABUoXjmyUFrWIgDGD8BqvbSZxNroghX43tuvgUbfqUcgoIQ8HprUkgs4CbwZil9l8IN38Cjb9SjkNeNCzEGQrNpiXphItyIoO8MgATJaEAMFBhztyZStNxgDefAo2/Uo5HFxCpAxZSYMhQtJHofbQn6xjBr5VErxIAUlAysWVdINFBfkHQMZMWqiA5b4EH8I26bscmmxNgKFeTiEoVhZwNyD0bcQEdHJiCZkrEABIu1ITyIPocBLDQ5lgAAkAm2pIGQBPJ4uT+jpP2RHAJMn5UtUcVUSIGMPB5OuxUkOqjQugIBQQhY0bSatmGm/Q+ekX72cg1SA5T1Xk8kgQ7xA+Ojyi4aIE68vO+UVQleoFkggAuG217yBU2DqxA1IpPJzjgSFwFot0ZLo1Kh0zECBCDaxiQRFVVvC3jQDSrjvALnMBwVsHnpykR7fGTkZPDYigEC1/gGegbWIJogIRuQ0xWMHJVk2lKw+g4k2ZFWD1zBL+UlCrgwGnB1np+7LCREZsUXKUsWgdyTq3g72MR/i0ozyB5YpHAPhjo3CbUUaXo+AkwAAQBHB2A4li5WFWk98rKC6QihYFWAiKZ+XBTb1Ywo+yJh+uWiZxCggxDLC5BxqwXVKoMRPfGV9KeFWh2DK7ezT01EUsnBIwjALajArFeicjDhUzIDEHg0HyggBByyMjYEQhsAfCPUMnK6NPhpu1Pa2lll5CFqSMuALlXQMTUPD66MMyhXqLGxCmqLhlkiTTBIMqgQTgUlY3ViQlBeYwTEkNIOr2FJmk3TF4iiX/Nr//aAAwDAQACAAMAAAAQ88888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888888889/8APPPPPPPPPPPPPPPPPPPPPPPPPPMnbPbTb9PPPPPPPPPPPPPPPPPPPPPPPVPO6fOPfPn9PPPPPPPPPPPPPPPPPPPOvPKbfPPLefPNvPPPPPPPPPPPPPPPPPPNfPtPPPPPLVPPnvPPPPPPPPPPPPPPPPOvfLfPPPPPPOPPC/PPPPPPPPPPPPPPPPL/ADw7zzzzzzzzTy3zzzzzzzzzzzzzzzzyvzxX7T3vHvDx3zrPTnPHTbzzzzzzzzzy7zxTb33332193zgz33331Xzzzzzzzzzzzzwq/wCU88F9c38std985+c8888888888u88r88188988X8o8858c8888888888888f88X8V8898988u884838888888888888908r/V889+f8ke8878U88888888888888f08+d882/87d888r8U888888888888888uy888888x/8APPPK/FPPPPPPPPPPPPPPPPLTFvPDjfPPPPPKvHvPPPPPPPPPPPPPPPPPO/PFfPPPPPPNPFfPPPPPPPPPPPPPPPPPO/fKfPPPPPPffnPPPPPPPPPPPPPPPPPPLVfLGfPPPOrvLPPPPPPPPPPPPPPPPPPPPP8Afzx87z8/zl/zzzzzzzzzzzzzzzzzzzzw3PDT333F8sPzzzzzzzzzzzzzzzzzzzzzzzx+zxzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz/xAAhEQEAAgIBBQEBAQAAAAAAAAABABEQMSEgMEBBYXFRcP/aAAgBAwEBPxD/ACwTETzOX0TeczSGdkRv8TbeOCqIXPk4AWsHouWhWybljcq8ZpW7wBv3Gb6CKyaG2afErW/rCgWxrHUKNmYIJTLjwgXKbDjP72Kfpm8PCVGVyHYqHNweEebnV+QL1PlLSmUy38nyw7LhLIC6nylMplM+Xc3cnj+QnL76wCDowLPvqIB99t8zOpjtqA+5yzvoUL+8GsDsZuUD9zncJxbivuK77aoc3nzO7O/NAY4T+5XCYXId6hc2Jjdnfiu+Z4k9Z2ca/wA73EOnOi3ERpm7O+Bc2G8fudG7Gv8AO/Vm5DTCEyZ0h8nlwBbEsejdjX+eAnHkQm118TyY7fS3Y1/ngijZN5zKrxlGBN+9ezjX+eGuRmi397FScO34fEf3PMnrrBWiU0KBbLh8MUbIJDLD0qKifQY4z78V38gCzOvRSfdgoBQwAr3EVvjMWobpNAzeUG2ewucBwlt3ORjFJ5Apqfafb/Lv/8QAKhEAAQIEBQMEAwEAAAAAAAAAAQARECExQUBRYXGhIDCxkcHR8HCB8eH/2gAIAQIBAT8Q/FhFUoAaHGSSp0WVgqyGNbAqFdVNPLDjSRgrCeUCTLlTY25X2hC3uEQYWgCQXCfI9b5wpLTKPaHMG2KXKZj0DWHCKf8ANHWdvjCZ9Gu0CEAKlDEPUA1Aop/TAhAKhDGOCJADlHId4Tc2n2GAKjxFgi88E4M5duGoIi/tfOCYFrGvv8IkAOUDWeq1kzNMzTN0DlgEN4DAFiCgA5KB7hayZmtZEVQQLzHehzDX2CfWOszVMgbdi0FRuogRoKdtwDkYz1CmXRf+igMDIxzUIP8ApAMjfdhqQQgDC6IoG/akukBnBSCDzfspnLDttr7KM0XlHhdKJaad80G45Tj6ygM3bvO1lojHdfeHG6Q55mUZrr4RGbvAPW706oRqtVUAHC43QCQA5VAoKQMwaCqAaQjzocj2HfOSRbj3jNk/qiMk2iQjZWE8onAvoudCpv7DAWpPCKMLdc5lHKYj086FTf2GBADA4U7kTUHd4jFQphM6zlawCbf2GDGR7x2Uew5kR5g2avg3I5TiB9Ty6xGoBEId0QgBdCCNsGACVCiEO0RAOxzVeh4DBF+8YZfDzhRSqKJgLGNvkDVitFyqYwRZzeBJzLN8IYBIYYCwoKZPuqsIhqxop1bG3U1nPCYzWTYZIiqMCoBiCBqtB6IAoHp+Lv/EACsQAQABAgQFBAMBAQEBAAAAAAERACExQVFhIHGBkaEwULHwEEDB0eHxkP/aAAgBAQABPxD/AObAQjOH8koaUGpWJUExSfJW870Pn3ku9KYXqLccjRwoZwqhBCyS9T8Kh7bh/OOCS2ZEnms4DlHuCSpcqwmA8qr3aFk2LsuaU/EEUcHQej7mYYIgkd/msb1AUYCYx1+AJ39TDSqfODapZGlNtox6ZDSr2QQcDmFnliTcPb3kDZ4GauAbtGGBcSaMhxbugY0EEGHCAlAatS4unyTRJaya+GiJN3Txn4WJA5mjuXKMGedZRK/RM5x9tgixCu4XXQxaCQiI+ocjQLHnhUQzkI7Hy2rBjAi6gR2Cm6poHQW35KmFxZHaufzS7K/qmuYiZR3/AMHnQl0h4NRLPEZ8pItrAw1GeV8QpBEsjl7Vcy3Adb/hmwViek5hbpr8YcDFCswBnV0Kh2O3/s7YUqqqq4r6AxACpT3MncvVj3GLWp8h44o3hMoOpH1jr7SHFmKI2oDCghfTNkwdXPgaE56ACVWs/pnEsj4MufpyT9KxMxMxzKMnBS+sarJ6ZcKABRCOZUS0UBhi8jM25e0MwQt/4KJzuDaeEkBXBZkz+FdN/VXhDu4ExP45IVBhjMQ5OiNk1OEWIJYLhgcnxJS1XWyRjqb+zBYeoFJyXA3ShGBwICAOnAkxP1HbqIKxGhjIy+swuSKsAWeYTzHXiGLI00S9zBJ2a+zOqJ6MFgjnJ3A4QohMjFCR5TPoevt4ZRJKWcjoMyS/MMnThIwqC0LvoCnYoEhQwj7JFNLrgKCXYos4BNgD44YleM1guRtIvX9AULE7jihyC8QBEQpng649x7INhB6T/wBj04WXhG6CP8paCiOKrP6CKY6JJ+hi8TbRhkZOj7JFCWQ8x8vscKksIH6KRSORoT4p05G2oknCLwDaBq9kJgwbfWHhwojMfpRIJKubPzLhJkkgOYeyEKR/FeFR92z8vQFKcGrGFYu/N/BXlOpeAEfyvIAf8pLEPtpX1j+UNgv00rw6L/K8TjfyvKG6YGeS+Sj7oxHB3cuv5kR/sPhAdwbuKSGHKnyhDgOk4TtWLH6FivCCaedwf5XlG/ypNhH6aUKwK/TKsWfL/KvE8v8AK8+bphy+tcp+7Q6HR/XIAy4UX8UCO+9ugHzR5lWhm2zX/nqJr8OQcRHGgKgNbEeQRjaPx9I5P7xYSOTKaDdCDdKKKomAH3H04yppZBN+xEdcv1wKz4UJCUulzwP4cQEhyBV7UIgiI3E9UGJYW6EHpD1/DOWG4Y3MG7Cj2F8IL5IHX1G1FZYlCx1YOv65gZvucjycIKkneE/tIijifgc5FUixAMhlJJrRyXDN/wBqvBPZwjwoeHY1VWW5bitQ9EB9yzpk8YKfUHxQEA5I+A/monhmueEAvO3OkB/VlTFfx9TJw5MMEhpDaZsiRGEdantKNiybEnfOkgCZpPh/ulRCxRfWTxQjBFOF0S65nCcCMjXNYXDdgpxg+adyuvFLnuF8VXDEj0KkvGR+vObKCd4eG1HSOcFnyHCvsAGBYB5SdOKK26M4gOUp6HErBgvCIAnI4jhCM62ZtHM9AdeFSJDdz4R+0+HhP9dOKRJkjqvl6vC52j3BxO5QTuf84m/vIA8A6cMhb7aGDqvhSrAOaALw8E1MXvSE0ymKz+0kOM3i35HTiFIchCXAeWJ9Medv7T4d7x4IB5a8B5QA+OETo0GsnrmOhwtbB20RkrAeIcn8wCwmc7X7allCDCOtR0zHkj3HonDMllMwhOzSQSxhGd1EPX0j332vhBW7lMRY9w9XC6l03ix6op0qFJUsq8UgM+eP5Q7PuCP7+4A7ZOQljmJ/64pyIhXEfCschp6R777XwocalOIbDrLwhS5FFgo8Sno04971+Sb7DuX7mLmIwGRqDYX0IMzZOHDiPEhCPSmqSqTtL0HvgnonvvtfAoWxdlrm1Vu7lRYXAIAMA4IWx3sL/wDo7DWOTI5GXje4P+ZRB+7ZYVUunaAzJvqTtR9CLSBJEeEXQbcwFnlqZlN8R/Ema19A999r/PzNCMugF10pfiLDyr9GAf8AeBRIFoAXVaXBKxo3rnFtCN/Qazew9LhNSlsjjObJydmxw2IUp0+m6zPhvSNYzBktVrs3OM999r/F6PSls0mAUhRDCf8Aj+WeQcBBlSNicTQ4ueGGPtS6WLXCHOUbTTJna4AQUSI2ThLQsTQ77O5Uz3mqgweNiw9+Id0Q949Km+MZQvM/pyoRiIrl1S658CgKsBitTD1KmOS3z2a+2rpdu7S5Jc2Ju6RR1+st1omI7PpwTMX14QXbKI6BiuxeiJRlNj3+DPPT29dLknkBMlolkos10EsnOcb9ZN6ATsgg2Sz6glglEAarRhVpQn3/AOTcq+VmOxcsA54sXX3JdrUgriF1XK7VHCsQXNhPZXc0R3udFoCvYFD1OJkICVWAp8obY86qdYKeX8ZYdmlOaUAM4OTLLMasu/rSdiT/AJnG4fs3ZNo0sMjGJxWEIKVJG+Nb/oooRa+QfkQLH3Dp7Nhvk8xmlAkBHbhA8kjdJbz+gef7cA+aN2BA2PyUxgjcT3Dv7PiMuPMvD5tYKGc0E6/oCiQr0hHk8uAwrudAD7OJJSLYgdAOEviwOY4lOeTx4ku9x68Fa6DB25zl2cAtm2zjZ3+zluvBcyzujxDlr/Rkk6yztLL1iSEYkh4nwbpR9A2yCD84avRB6iClCMuxVZX2coSErrYnNNEoBDghI9uFRYgJA4iVZL1JVMzHk58/Uj9uG7/hq5VNDHgMXLaeWXY/JosIyVl/kKjf2lZRDfUtzOaeztxLZBMAckqaNme5Fg2b86W9UNo0Ruei494FQM9S5dYq2ZgQ5Z8B1ngSiHOgsWOWbsUvgz5pn2kp6h5J8m1MkMS76hqsnplxhY1knKFzo1IwnAjybMc1p05XkbmCPNSV8NbR2HoC+GkYD969AAS5xTuWizVf2g2piTfj4tbDwoAAFgCA4JD4kxXIDNdKu5lfjUd2b0y9rtv08oMx0pAy534nBtief0nRgHFPQNN2DeicyuHWrqs3tHtp6KQ5DBHJo8z2sRZQw8XnREBJCHNbOp6whMLJjsGK2JaFS3RZQ6/27KdcMvp/zangFFmiGSRYWJM5yqHCNGxqCSFjlClAqqrjFDBsluVELceimAarf2xmvSlGolyurhkconvNEMzRLveRyho45v3ytB6UBJb9EeJIA4gHdp1Hsp518UanMwTmtyjMW5zRpkdAaxlSo3V/JZoUOcAz0MQ/tOhHFEVQN1sY20phAAwwIFC0xB09wFGS1GwYyO8NAR1afLQeHc0JfuihUMcSA8NMX7FK7v8A82v/2SAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIA==)

**Fall 2021**

**Table of Contents**

[Abstract 3](#_Toc89686015)

[Objective 4](#_Toc89686016)

[System-level Block Diagram 4](#_Toc89686017)

[Hardware Components 4](#_Toc89686018)

[**UART-TTL Converter:** 5](#_Toc89686019)

[**DE1-SoC FPGA Development Kit:** 5](#_Toc89686020)

[Matrix Manipulation Theory 6](#_Toc89686021)

[**Pseudo code for Matrix Addition:** 6](#_Toc89686022)

[**Pseudo code for Matrix Subtraction** 6](#_Toc89686023)

[**Pseudo code for Multiplication:** 7](#_Toc89686024)

[**Pseudo code for Transpose of Matrix:** 8](#_Toc89686025)

[**Pseudo code for Determinant of Matrix:** 8](#_Toc89686026)

[Algorithm 10](#_Toc89686027)

[**Algorithm for UART Decoder:** 10](#_Toc89686028)

[**Algorithm for UART Transmitter:** 10](#_Toc89686029)

[**Algorithm for FIFO:** 11](#_Toc89686030)

[**Algorithm for Matrix Calculator:** 12](#_Toc89686031)

[Results 13](#_Toc89686032)

[Conclusion 14](#_Toc89686033)

[Future improvements 14](#_Toc89686034)

[References 15](#_Toc89686035)

[Appendix 16](#_Toc89686036)

[**Code** 16](#_Toc89686037)

[**VHDL code for TOP level entity** 16](#_Toc89686038)

[**VHDL code for MATRIX\_CALCULATOR\_sys** 17](#_Toc89686039)

[**VHDL code for UART Decoder** 44](#_Toc89686040)

[**VHDL code for UART Transmitter:** 45](#_Toc89686041)

[**VHDL code for FIFO:** 47](#_Toc89686042)

[**Nios C code:** 49](#_Toc89686043)

Abstract

Matrix manipulation includes operations such as addition, subtraction, multiplication, inverse, and transpose etc., on the array of data stored as rows and columns. It is an essential process used in diverse fields of science and commerce including but not limited to Computer technology, Optics, Geology, Cryptography, Network Theory, Robotics and Animations, and Finance. Real-time matrix operations include a large number of computations, required for process control, and data & signal processing, which directly impacts the system performance. Real-time matrix calculation becomes a bottleneck for performance of fast system applications as it requires large computation power, memory, and time.

In this project, we present a design which can perform matrix manipulations such as addition, subtraction, scalar and matrix array multiplication, determinant of matrix, co-factor and other vital matrix operations required for real-time signal processing. The matrix manipulator is developed using Intel DE1-SoC development board with Cyclone V processor is interfaced with FT232R FTDI UART to establish serial communication between the FPGA board and PC. The matrix calculator is implemented in the NIOS II soft-core processor present on DE1-SoC board, the inputs are fed from a host computer onto FPGA board via UART serial port, a USB to TTL convertor module will be used to establish serial communication. The final computational results are fetched using the serial communication onto the remote PC.

Objective

Real-time signal processing system involves large computations and complex process control operations on massive array of data which is highly time-consuming. Currently, most of matrix operations are performed using software. The expansion of matrix dimension and reduction in processing speed has become bottleneck for the most of the existing real-time fast system applications. The objective of this project is to develop a Real-time Matrix-Manipulator using UART to TTL convertor for serial communication, Intel DE1-SoC FPGA Development Kit, and TRDB- TLM Touch screen LCD Display. The input matrix values are served into the FPGA board using Serial communication from a remote system. The matrix operations are executed in NIOS-II processor available in DE1-SoC board. The manipulated resultant matrix is displayed in the LCD display. The NIOS –II processor is used to control system operation and perform basic matrix operations such as addition, subtraction, Multiplication, finding determinant, co-factor, and other essential matrix operations required for real-time signal processing.

System-level Block Diagram

The system-level Block diagram for the Real-time Matrix Manipulator is shown in figure 1. The major functional blocks include the Remote PC, UART TTL convertor, the DE1-SoC board and the TRDB-TLM LCD display.

![](data:image/png;base64,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)

SDRAM

UART RX

NIOS II

Matrix Operation Algorithm

SSRAM

UART TX

UART

PIO

**USB to UART**

Serial communication

**DE1-SoC**

**PC**

**Figure 1: System-level Block Diagram**

Hardware Components

The developed Real-Time Matrix Manipulator consists of the following hardware components:

1. UART-TTL Convertor – FT232R FTDI
2. DE1-SoC Development Kit

**UART-TTL Converter:**

***![C:\Users\skoki\AppData\Local\Microsoft\Windows\INetCache\Content.MSO\E1CA1ACE.tmp](data:image/jpeg;base64,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)***

**Figure 2. FT232R FTDI USB UART**

The USB UART-TTL converter used is an FT232R FTDI (Future Technology Device International Ltd.) chip on a breakout board that simplifies serial communication by reducing the external components. Figure 2 shows the package of the USB UART. It is a fully integrated chip with 1024-bit EEPROM, clock generation, and USB termination resistors. The FT232R serial UART can support data rate transfer rates from 300 baud to 3 Mbaud at the TTL levels (FT232R, n.d.). High data throughput is achieved through the 128 bytes receive buffer and the 256 bytes transmit buffer that utilizes smooth buffer technology. The UART interface will support 7 or 8 data bits with 1 or 2 bits for representing odd, even, mark, space and non-parity bits (FT232R, n.d.). The configurable I/O pins integrated +3.3V level convertor provides output drive strength for various applications. It can be used as interface with MCU/ PLD/FPGA based designs, PDA to USB data transfer, smart card readers, Industrial control, Hardware and Wireless modems, Bar Code Readers, and Cellular Phone USB data transfer cables and interfaces ((FT232R, n.d.).

The communication is established by making use of the UART Rx and Tx lines going to pins 1 and 3 on the 20-pin expansion header of DE1-SoC board. It allows any computer to open a serial port and communicate to the DE1-SoC over a COM port, inputting the equations needed for the Matrix equations. In addition, the DE1-SoC can transmit data back to the computer by sending UART data to the FTDI board, which will display on the serial port screen for the user.

**DE1-SoC FPGA Development Kit:**

The DE1-Soc Development kit provides a hardware platform that combines the System-on Chip (SoC) FPGA and dual-core Cyclone- A9 embedded core which can be used for wide industrial application improvement. It provides users the power of flexibility in design, paired with high-processor, low-power processing system. It provides seamless integration of both SoC and ARM based hard processor system (HPS), including processor, memory and peripheral interfaces over a high-bandwidth interconnect backbone. The DE1SoC board includes hardware such as high-speed DDR3 memory, video and audio capability, Ethernet, networking and much more.

Matrix Manipulation Theory

Matrices are representation of array of data commonly used in extensive real-world data processing, research, and scientific studies. Matrix Multiplication provides good approximation for complicated calculation of real-time sensitive engineering applications signal processing, image processing, network theory and many more. Matrix manipulation is engaged with every part of day-to-day life including data base management, encryption that helps security, 3D gaming, robotics and animation, create models for economic and business, construction, physics, and geology. The common matric calculations involved are addition, subtraction, multiplication, transpose, finding the determinant value and inverse of the matrix.

**Pseudo code for Matrix Addition:**

Matrix addition can be performed only when both the matrices under operation are of same size. It is commonly employed in data, image and signal processing. The void matrix\_addition() performs the following activity:

for (i=0;i<r1;i++)

{

for (j=0;j<c1;j++)

{

res[i][j]= a[i][j]+b[i][j];

}

}

**Pseudo code for Matrix Subtraction**

Matrix subtraction is a linear algebraic operation which can be performed only when both the matrices under operation are of same size. The void matrix\_subraction() performs the following operation:

for (i=0;i<r1;i++)

{

for (j=0;j<c1;j++)

{

res[i][j]= a[i][j]-b[i][j];

}

}

**Pseudo code for Multiplication:**

Matrix Multiplication can be either scalar or matrix multiplication, and is the most challenging algebraic operation. Matrix multiplication can be either scalar, vector or matrix multiplication. Scalar multiplication is a element-wise multiplication of matrix elements using a real or complex value. In the below defined code, *void scalar\_matrix\_multiplication()* executes matrix multiplication using constant value k.

for (i=0;i<r1;i++)

{

for (j=0;j<c1;j++)

{

res[i][j] = k\*a[i][j];

}

}

Multiplication of matrices can be executed under the condition that the number of rows of first matrix should be equal to number of columns in the second matrix (i.e. [A]i x j\* [B]m x n = [C]i x n.

if (r1 != c2)

{

printf("Matrix multiplication cannot be performed\n");

}

else

for (i=0;i<r1;i++)

{

for (j=0;j<c2;j++)

{

res[i][j]=0;

for (k=0; k<c1;k++)

res[i][j] += a[i][k]\*b[k][j];

}

}

**Pseudo code for Transpose of Matrix:**

Transpose is simply interchanging the rows and columns. It is generally employed when multiple matrix exists and the dimensions without transposing is not amendable for matrix operations. In real-time one usage of transpose is data manipulation, where the application requires the use of orthonormal matrix. In image processing switching rows and columns of pixels can result in exchanging the domain and space of the image transformation. In neural networks, frequent process weight and inputs of different sizes where the dimensions do not meet the requirement of algorithm can be accomplished using simple transpose of matrix.

for (i=0;i<c1;i++)

{

for (j=0;j<r1;j++)

{

res[i][j] = a[j][i];

}

}

**Pseudo code for Determinant of Matrix:**

Determinant is the number associated with square matrix that encodes information about the matrix. Determinant of matrix is used to check the consistency of any system and to solve linear equations.

for (int f = 0; f < n; f++)

{

// Getting Cofactor of a[0][f]

temp= malloc(2\*sizeof\*temp);

for (i=0; i< 2; i++)

{

temp[i]= malloc(2\*sizeof\*temp[i]);

}

i=0;

// Looping for each element of the matrix

for (int row = 0; row < n; row++)

{

for (int col = 0; col < n; col++)

{

// Copying into temporary matrix only those

// element which are not in given row and

// column

if (row != 0 && col != f)

{

temp[i][j++] = a[row][col];

// Row is filled, so increase row index and

// reset col index

if (j == n - 1)

{

j = 0;

i++;

}

}

}

}

if(f%2==0)

{

(D += a[0][f]\*(matrix\_det(temp, n - 1,n - 1)));

}

else

{

D -= a[0][f]\*(matrix\_det(temp, n - 1,n - 1));

}

// terms are to be added with alternate sign

D1=D;

Algorithm

**Algorithm for UART Decoder:**

The UART Decoder accepts 2 inputs and has 2 outputs. The first input is Clk, with a frequency set by the generic variable ClockRate. The second input is Rx, which is the pin state of the UART Rx pin. The first output is Complete, a single bit that is low while receiving Uart data and high once the Uart byte is fully decoded. The second output is Data, an 8-bit vector that is decoded value from the Rx pin. The VHDL code for the UART decoder works as follows:

1. Input the clock rate and baud rate using the generic map, as this will not change throughout operation.
2. Wait for the start-bit from UART Rx (High->Low Transition).
3. Begin counting the clock cycles until we reach the necessary baud rate.
4. Halfway-through the count, sample the Rx line and save it in data\_register, this ensures we sample when the data line is stable.
5. Once the count reaches the baud value, reset the count
6. Repeat until all 10 bits have been sampled (start bit, data bits, stop bit).
7. Once all bits have been sampled, set the Complete signal to indicate Data is stable
8. Wait for next start-bit.

This isn’t sufficient, however, for the NIOS processor to use, since it will stream all the data in immediately. We can make use of interrupts inside the NIOS processor to react whenever the Complete signal rises, but it will take time away from performing calculations. We decided to make use of the decoder by also implementing a FIFO (First In First Out) buffer, which will buffer in up to 128 bytes of UART data to be read out by the NIOS processor when it’s ready.

**Algorithm for UART Transmitter:**

The VHDL code for the UART transmitter is very similar to the Decoder, but in reverse. It has 3 inputs and a single output. The first input is Clk, the system clock with frequency specified in the generic ClockRate. The second input is Send, a single bit that triggers the send sequence on a low to high transition. The third input is Data, an 8-bit vector that is the value to send over UART. It also has a single output, Tx, which should be tied to the Tx pin on the DE1 board. The transmitter works as follows:

1. Input clock rate and baud rate using generic map, as this will not change throughout operation
2. Wait for low->high transition on Send input
3. Bring Tx low, and begin counting clock cycles until we reach necessary baud rate
4. Once the count has rolled over, change the Tx state based on the bit of Data
5. Repeat until all 8 data bits have been sent
6. Bring Tx high to send the stop bit.
7. Reset all variables back to original states and wait for next low->high transition.

Following this we can control the transmitter tying a parallel IO in the NIOS processor to send the start signal, and the data can be tied to another parallel IO. The Clk and Tx bits are tied to the 50 Mhz clock and UART Tx pin respectively, and this is everything necessary to integrate a UART transmitter into our NIOS design.

**Algorithm for FIFO:**

The VHDL code for the FIFO is very simple and elegant. It uses 4 inputs and 1 output. The first input is complete, which indicates that data is complete and ready to be pushed into the FIFO. The next is data\_in, an 8 bit vector that is the data to be pushed in. The third is pop, which will pop out the data and point data\_out to the next data to be sent out. The final input is clear, which clears and resets the FIFO so that it’s as if it had just started. The only output of the FIFO is data\_out, an 8-bit vector that is the data to be sent out. The operation for the FIFO is very simple, first configure the generic num to the amount of data you want to buffer. Then, tie the data\_in signal to some data you want buffered, and whenever you press complete, it will be buffered into the FIFO. Meanwhile, data\_out is always the oldest data in the buffer, and you can point data\_out to the next oldest data by pressing pop. Clear can be tied to a debug pin so that you can manually clear the FIFO during development. The process for the FIFO is as follows:

1. Configure the depth of the FIFO with the num generic value
2. Wait for low->high transition on the complete input or pop input or clear input
3. If low->high on complete…
   1. Copy data\_in into the mem (an array of size num of 8-bit vectors) signal at location start
   2. Increment start by one
4. If low->high on pop…
   1. Increment stop by one
5. If low->high on clear…
   1. Set start and stop both to 0
6. Check if start is equal to stop
7. If yes…
   1. Output “00000000”
8. Otherwise…
   1. Output the value in mem at location stop

**Algorithm for Matrix Calculator:**

The NIOS C code for calculator can read matrix of any order and can implement addition, subtraction, multiplication, transpose and also calculates determinant. Order of two matrices, values into two matrices and type of operation needs to be entered into a FIFO and when C code is built and run, the values are fetched into rows, columns and as elements of two matrices. The row and column sizes are dynamically allocated. So, there is no restriction on the order of the matrices. The process is as follows:

1. Inside main, declare variables that store row and column numbers of two matrices, chooses type of operation, array elements
2. Values into variables are read by decoding the values from parallel IO, which in turn fetches the value from FIFO
3. A function is used to indicate next value from parallel IO to be read
4. Based on the operation selected, the corresponding C function is called
5. Matrix operation is performed, and result is written into a parallel IO which is connected UART Tx and the results are displayed on the remote terminal

Results

Case 1: Two matrices of order (1,1)

A(1,1)=10; B(1,1)=10

Option selected: Addition

![](data:image/png;base64,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)

Output: Sum of 10+10 = 20

Case 2: Two matrices of order(1,1)

A(1,1)=10;B(1,1)=20;

Option selected: Determinant

![](data:image/png;base64,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)

Output: Determinant of matrix A is 10; Determinant of matrix B is 20

Case 3: Two matrices of order(3,3)

A(3,3)=1,0,0;0,1,0;0,0,1;B(3,3)=2,0,0;0,2,0;0,0,2;

Option selected: Determinant

![](data:image/png;base64,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)

Output: Determinant of matrix A is 1; Determinant of matrix B is 8

Conclusion

Primary goal to use Nios II soft core processor and establish UART communication with USB to TTL converter interface is successfully achieved. There is no constraint on the amount of input data that can be read using UART within the hardware capability.

Future improvements

1. The matrix operations can be made generic to deal with different formats of data like float, double etc
2. The speed of UART Rx and Tx can be improved, the decoder can be made more robust to read large amount of data correctly
3. Extensive validation of the code was not feasible within the project timeline

References

1. *Future Technology Devices International LTD FT232R USB ...* (n.d.). <https://ftdichip.com/wp-content/uploads/2020/08/DS_FT232R.pdf>.
2. *DE1-SoC User Manual.*

[*https://www.intel.com/content/dam/altera-www/global/en\_US/portal/dsn/42/doc-us-dsnbk-42-1004282204-de1-soc-user-manual.pdf*](https://www.intel.com/content/dam/altera-www/global/en_US/portal/dsn/42/doc-us-dsnbk-42-1004282204-de1-soc-user-manual.pdf)

1. *Nios-II software development.*

[*https://www.uio.no/studier/emner/matnat/fys/FYS4220/h20/lecture-slides/embedded\_niosii\_sw\_dev.pdf*](https://www.uio.no/studier/emner/matnat/fys/FYS4220/h20/lecture-slides/embedded_niosii_sw_dev.pdf)

Appendix

**Code**

**VHDL code for TOP level entity**

library IEEE;

use IEEE.std\_logic\_1164.all;

use IEEE.numeric\_std.all;

entity MATRIX\_CALCULATOR is

port (

CLOCK\_50 : in std\_logic := '0'; -- clk.clk

UART\_RX : in std\_logic;

SW : in std\_logic\_vector(9 downto 0);

UART\_TX : out std\_logic;

LEDR : out std\_logic\_vector(9 downto 0)

);

end entity MATRIX\_CALCULATOR;

architecture Behavior of MATRIX\_CALCULATOR is

signal next\_write : std\_logic\_vector(7 downto 0);

signal toWrite : std\_logic\_vector(7 downto 0);

signal next\_read : std\_logic\_vector(7 downto 0);

signal toRead : std\_logic\_vector(7 downto 0);

signal gotUart : std\_logic;

signal decodedRead: std\_logic\_vector(7 downto 0);

component MATRIX\_CALCULATOR\_sys is

port (

clk\_clk : in std\_logic := '0'; -- clk.clk

nextval\_external\_connection\_export : out std\_logic\_vector(7 downto 0); -- nextval\_external\_connection.export

nextwriteval\_external\_connection\_export : out std\_logic\_vector(7 downto 0); -- nextwriteval\_external\_connection.export

readval\_external\_connection\_export : in std\_logic\_vector(7 downto 0) := (others => '0'); -- readval\_external\_connection.export

writeval\_external\_connection\_export : out std\_logic\_vector(7 downto 0) -- writeval\_external\_connection.export

);

end component;

begin

calculator : MATRIX\_CALCULATOR\_sys port map (CLOCK\_50, next\_read, next\_write, toRead, toWrite);

uart\_decoder : entity work.Uart\_Decoder port map (CLOCK\_50, UART\_RX, gotUart, decodedRead);

uart\_transmitter : entity work.Uart\_Transmitter port map (CLOCK\_50, next\_write(0), toWrite, UART\_TX);

read\_fifo : entity work.FIFO generic map (128) port map (gotUart, decodedRead, next\_read(0), SW(0), toRead);

LEDR(7 downto 0) <= toRead;

end Behavior;

**VHDL code for MATRIX\_CALCULATOR\_sys**

-- MATRIX\_CALCULATOR.vhd

-- Generated using ACDS version 18.1 625

library IEEE;

use IEEE.std\_logic\_1164.all;

use IEEE.numeric\_std.all;

entity MATRIX\_CALCULATOR\_sys is

port (

clk\_clk : in std\_logic := '0'; -- clk.clk

nextval\_external\_connection\_export : out std\_logic\_vector(7 downto 0); -- nextval\_external\_connection.export

nextwriteval\_external\_connection\_export : out std\_logic\_vector(7 downto 0); -- nextwriteval\_external\_connection.export

readval\_external\_connection\_export : in std\_logic\_vector(7 downto 0) := (others => '0'); -- readval\_external\_connection.export

writeval\_external\_connection\_export : out std\_logic\_vector(7 downto 0) -- writeval\_external\_connection.export

);

end entity MATRIX\_CALCULATOR\_sys;

architecture rtl of MATRIX\_CALCULATOR\_sys is

component MATRIX\_CALCULATOR\_jtag\_uart\_0 is

port (

clk : in std\_logic := 'X'; -- clk

rst\_n : in std\_logic := 'X'; -- reset\_n

av\_chipselect : in std\_logic := 'X'; -- chipselect

av\_address : in std\_logic := 'X'; -- address

av\_read\_n : in std\_logic := 'X'; -- read\_n

av\_readdata : out std\_logic\_vector(31 downto 0); -- readdata

av\_write\_n : in std\_logic := 'X'; -- write\_n

av\_writedata : in std\_logic\_vector(31 downto 0) := (others => 'X'); -- writedata

av\_waitrequest : out std\_logic; -- waitrequest

av\_irq : out std\_logic -- irq

);

end component MATRIX\_CALCULATOR\_jtag\_uart\_0;

component MATRIX\_CALCULATOR\_nextval is

port (

clk : in std\_logic := 'X'; -- clk

reset\_n : in std\_logic := 'X'; -- reset\_n

address : in std\_logic\_vector(1 downto 0) := (others => 'X'); -- address

write\_n : in std\_logic := 'X'; -- write\_n

writedata : in std\_logic\_vector(31 downto 0) := (others => 'X'); -- writedata

chipselect : in std\_logic := 'X'; -- chipselect

readdata : out std\_logic\_vector(31 downto 0); -- readdata

out\_port : out std\_logic\_vector(7 downto 0) -- export

);

end component MATRIX\_CALCULATOR\_nextval;

component MATRIX\_CALCULATOR\_nios2\_gen2\_0 is

port (

clk : in std\_logic := 'X'; -- clk

reset\_n : in std\_logic := 'X'; -- reset\_n

reset\_req : in std\_logic := 'X'; -- reset\_req

d\_address : out std\_logic\_vector(17 downto 0); -- address

d\_byteenable : out std\_logic\_vector(3 downto 0); -- byteenable

d\_read : out std\_logic; -- read

d\_readdata : in std\_logic\_vector(31 downto 0) := (others => 'X'); -- readdata

d\_waitrequest : in std\_logic := 'X'; -- waitrequest

d\_write : out std\_logic; -- write

d\_writedata : out std\_logic\_vector(31 downto 0); -- writedata

debug\_mem\_slave\_debugaccess\_to\_roms : out std\_logic; -- debugaccess

i\_address : out std\_logic\_vector(17 downto 0); -- address

i\_read : out std\_logic; -- read

i\_readdata : in std\_logic\_vector(31 downto 0) := (others => 'X'); -- readdata

i\_waitrequest : in std\_logic := 'X'; -- waitrequest

irq : in std\_logic\_vector(31 downto 0) := (others => 'X'); -- irq

debug\_reset\_request : out std\_logic; -- reset

debug\_mem\_slave\_address : in std\_logic\_vector(8 downto 0) := (others => 'X'); -- address

debug\_mem\_slave\_byteenable : in std\_logic\_vector(3 downto 0) := (others => 'X'); -- byteenable

debug\_mem\_slave\_debugaccess : in std\_logic := 'X'; -- debugaccess

debug\_mem\_slave\_read : in std\_logic := 'X'; -- read

debug\_mem\_slave\_readdata : out std\_logic\_vector(31 downto 0); -- readdata

debug\_mem\_slave\_waitrequest : out std\_logic; -- waitrequest

debug\_mem\_slave\_write : in std\_logic := 'X'; -- write

debug\_mem\_slave\_writedata : in std\_logic\_vector(31 downto 0) := (others => 'X'); -- writedata

dummy\_ci\_port : out std\_logic -- readra

);

end component MATRIX\_CALCULATOR\_nios2\_gen2\_0;

component MATRIX\_CALCULATOR\_onchip\_memory2\_0 is

port (

clk : in std\_logic := 'X'; -- clk

address : in std\_logic\_vector(13 downto 0) := (others => 'X'); -- address

clken : in std\_logic := 'X'; -- clken

chipselect : in std\_logic := 'X'; -- chipselect

write : in std\_logic := 'X'; -- write

readdata : out std\_logic\_vector(31 downto 0); -- readdata

writedata : in std\_logic\_vector(31 downto 0) := (others => 'X'); -- writedata

byteenable : in std\_logic\_vector(3 downto 0) := (others => 'X'); -- byteenable

reset : in std\_logic := 'X'; -- reset

reset\_req : in std\_logic := 'X'; -- reset\_req

freeze : in std\_logic := 'X' -- freeze

);

end component MATRIX\_CALCULATOR\_onchip\_memory2\_0;

component MATRIX\_CALCULATOR\_readval is

port (

clk : in std\_logic := 'X'; -- clk

reset\_n : in std\_logic := 'X'; -- reset\_n

address : in std\_logic\_vector(1 downto 0) := (others => 'X'); -- address

readdata : out std\_logic\_vector(31 downto 0); -- readdata

in\_port : in std\_logic\_vector(7 downto 0) := (others => 'X') -- export

);

end component MATRIX\_CALCULATOR\_readval;

component MATRIX\_CALCULATOR\_mm\_interconnect\_0 is

port (

clk\_0\_clk\_clk : in std\_logic := 'X'; -- clk

nios2\_gen2\_0\_reset\_reset\_bridge\_in\_reset\_reset : in std\_logic := 'X'; -- reset

nios2\_gen2\_0\_data\_master\_address : in std\_logic\_vector(17 downto 0) := (others => 'X'); -- address

nios2\_gen2\_0\_data\_master\_waitrequest : out std\_logic; -- waitrequest

nios2\_gen2\_0\_data\_master\_byteenable : in std\_logic\_vector(3 downto 0) := (others => 'X'); -- byteenable

nios2\_gen2\_0\_data\_master\_read : in std\_logic := 'X'; -- read

nios2\_gen2\_0\_data\_master\_readdata : out std\_logic\_vector(31 downto 0); -- readdata

nios2\_gen2\_0\_data\_master\_write : in std\_logic := 'X'; -- write

nios2\_gen2\_0\_data\_master\_writedata : in std\_logic\_vector(31 downto 0) := (others => 'X'); -- writedata

nios2\_gen2\_0\_data\_master\_debugaccess : in std\_logic := 'X'; -- debugaccess

nios2\_gen2\_0\_instruction\_master\_address : in std\_logic\_vector(17 downto 0) := (others => 'X'); -- address

nios2\_gen2\_0\_instruction\_master\_waitrequest : out std\_logic; -- waitrequest

nios2\_gen2\_0\_instruction\_master\_read : in std\_logic := 'X'; -- read

nios2\_gen2\_0\_instruction\_master\_readdata : out std\_logic\_vector(31 downto 0); -- readdata

jtag\_uart\_0\_avalon\_jtag\_slave\_address : out std\_logic\_vector(0 downto 0); -- address

jtag\_uart\_0\_avalon\_jtag\_slave\_write : out std\_logic; -- write

jtag\_uart\_0\_avalon\_jtag\_slave\_read : out std\_logic; -- read

jtag\_uart\_0\_avalon\_jtag\_slave\_readdata : in std\_logic\_vector(31 downto 0) := (others => 'X'); -- readdata

jtag\_uart\_0\_avalon\_jtag\_slave\_writedata : out std\_logic\_vector(31 downto 0); -- writedata

jtag\_uart\_0\_avalon\_jtag\_slave\_waitrequest : in std\_logic := 'X'; -- waitrequest

jtag\_uart\_0\_avalon\_jtag\_slave\_chipselect : out std\_logic; -- chipselect

nextval\_s1\_address : out std\_logic\_vector(1 downto 0); -- address

nextval\_s1\_write : out std\_logic; -- write

nextval\_s1\_readdata : in std\_logic\_vector(31 downto 0) := (others => 'X'); -- readdata

nextval\_s1\_writedata : out std\_logic\_vector(31 downto 0); -- writedata

nextval\_s1\_chipselect : out std\_logic; -- chipselect

nextwriteval\_s1\_address : out std\_logic\_vector(1 downto 0); -- address

nextwriteval\_s1\_write : out std\_logic; -- write

nextwriteval\_s1\_readdata : in std\_logic\_vector(31 downto 0) := (others => 'X'); -- readdata

nextwriteval\_s1\_writedata : out std\_logic\_vector(31 downto 0); -- writedata

nextwriteval\_s1\_chipselect : out std\_logic; -- chipselect

nios2\_gen2\_0\_debug\_mem\_slave\_address : out std\_logic\_vector(8 downto 0); -- address

nios2\_gen2\_0\_debug\_mem\_slave\_write : out std\_logic; -- write

nios2\_gen2\_0\_debug\_mem\_slave\_read : out std\_logic; -- read

nios2\_gen2\_0\_debug\_mem\_slave\_readdata : in std\_logic\_vector(31 downto 0) := (others => 'X'); -- readdata

nios2\_gen2\_0\_debug\_mem\_slave\_writedata : out std\_logic\_vector(31 downto 0); -- writedata

nios2\_gen2\_0\_debug\_mem\_slave\_byteenable : out std\_logic\_vector(3 downto 0); -- byteenable

nios2\_gen2\_0\_debug\_mem\_slave\_waitrequest : in std\_logic := 'X'; -- waitrequest

nios2\_gen2\_0\_debug\_mem\_slave\_debugaccess : out std\_logic; -- debugaccess

onchip\_memory2\_0\_s1\_address : out std\_logic\_vector(13 downto 0); -- address

onchip\_memory2\_0\_s1\_write : out std\_logic; -- write

onchip\_memory2\_0\_s1\_readdata : in std\_logic\_vector(31 downto 0) := (others => 'X'); -- readdata

onchip\_memory2\_0\_s1\_writedata : out std\_logic\_vector(31 downto 0); -- writedata

onchip\_memory2\_0\_s1\_byteenable : out std\_logic\_vector(3 downto 0); -- byteenable

onchip\_memory2\_0\_s1\_chipselect : out std\_logic; -- chipselect

onchip\_memory2\_0\_s1\_clken : out std\_logic; -- clken

readval\_s1\_address : out std\_logic\_vector(1 downto 0); -- address

readval\_s1\_readdata : in std\_logic\_vector(31 downto 0) := (others => 'X'); -- readdata

writeval\_s1\_address : out std\_logic\_vector(1 downto 0); -- address

writeval\_s1\_write : out std\_logic; -- write

writeval\_s1\_readdata : in std\_logic\_vector(31 downto 0) := (others => 'X'); -- readdata

writeval\_s1\_writedata : out std\_logic\_vector(31 downto 0); -- writedata

writeval\_s1\_chipselect : out std\_logic -- chipselect

);

end component MATRIX\_CALCULATOR\_mm\_interconnect\_0;

component MATRIX\_CALCULATOR\_irq\_mapper is

port (

clk : in std\_logic := 'X'; -- clk

reset : in std\_logic := 'X'; -- reset

receiver0\_irq : in std\_logic := 'X'; -- irq

sender\_irq : out std\_logic\_vector(31 downto 0) -- irq

);

end component MATRIX\_CALCULATOR\_irq\_mapper;

component altera\_reset\_controller is

generic (

NUM\_RESET\_INPUTS : integer := 6;

OUTPUT\_RESET\_SYNC\_EDGES : string := "deassert";

SYNC\_DEPTH : integer := 2;

RESET\_REQUEST\_PRESENT : integer := 0;

RESET\_REQ\_WAIT\_TIME : integer := 1;

MIN\_RST\_ASSERTION\_TIME : integer := 3;

RESET\_REQ\_EARLY\_DSRT\_TIME : integer := 1;

USE\_RESET\_REQUEST\_IN0 : integer := 0;

USE\_RESET\_REQUEST\_IN1 : integer := 0;

USE\_RESET\_REQUEST\_IN2 : integer := 0;

USE\_RESET\_REQUEST\_IN3 : integer := 0;

USE\_RESET\_REQUEST\_IN4 : integer := 0;

USE\_RESET\_REQUEST\_IN5 : integer := 0;

USE\_RESET\_REQUEST\_IN6 : integer := 0;

USE\_RESET\_REQUEST\_IN7 : integer := 0;

USE\_RESET\_REQUEST\_IN8 : integer := 0;

USE\_RESET\_REQUEST\_IN9 : integer := 0;

USE\_RESET\_REQUEST\_IN10 : integer := 0;

USE\_RESET\_REQUEST\_IN11 : integer := 0;

USE\_RESET\_REQUEST\_IN12 : integer := 0;

USE\_RESET\_REQUEST\_IN13 : integer := 0;

USE\_RESET\_REQUEST\_IN14 : integer := 0;

USE\_RESET\_REQUEST\_IN15 : integer := 0;

ADAPT\_RESET\_REQUEST : integer := 0

);

port (

reset\_in0 : in std\_logic := 'X'; -- reset

clk : in std\_logic := 'X'; -- clk

reset\_out : out std\_logic; -- reset

reset\_req : out std\_logic; -- reset\_req

reset\_req\_in0 : in std\_logic := 'X'; -- reset\_req

reset\_in1 : in std\_logic := 'X'; -- reset

reset\_req\_in1 : in std\_logic := 'X'; -- reset\_req

reset\_in2 : in std\_logic := 'X'; -- reset

reset\_req\_in2 : in std\_logic := 'X'; -- reset\_req

reset\_in3 : in std\_logic := 'X'; -- reset

reset\_req\_in3 : in std\_logic := 'X'; -- reset\_req

reset\_in4 : in std\_logic := 'X'; -- reset

reset\_req\_in4 : in std\_logic := 'X'; -- reset\_req

reset\_in5 : in std\_logic := 'X'; -- reset

reset\_req\_in5 : in std\_logic := 'X'; -- reset\_req

reset\_in6 : in std\_logic := 'X'; -- reset

reset\_req\_in6 : in std\_logic := 'X'; -- reset\_req

reset\_in7 : in std\_logic := 'X'; -- reset

reset\_req\_in7 : in std\_logic := 'X'; -- reset\_req

reset\_in8 : in std\_logic := 'X'; -- reset

reset\_req\_in8 : in std\_logic := 'X'; -- reset\_req

reset\_in9 : in std\_logic := 'X'; -- reset

reset\_req\_in9 : in std\_logic := 'X'; -- reset\_req

reset\_in10 : in std\_logic := 'X'; -- reset

reset\_req\_in10 : in std\_logic := 'X'; -- reset\_req

reset\_in11 : in std\_logic := 'X'; -- reset

reset\_req\_in11 : in std\_logic := 'X'; -- reset\_req

reset\_in12 : in std\_logic := 'X'; -- reset

reset\_req\_in12 : in std\_logic := 'X'; -- reset\_req

reset\_in13 : in std\_logic := 'X'; -- reset

reset\_req\_in13 : in std\_logic := 'X'; -- reset\_req

reset\_in14 : in std\_logic := 'X'; -- reset

reset\_req\_in14 : in std\_logic := 'X'; -- reset\_req

reset\_in15 : in std\_logic := 'X'; -- reset

reset\_req\_in15 : in std\_logic := 'X' -- reset\_req

);

end component altera\_reset\_controller;

signal nios2\_gen2\_0\_debug\_reset\_request\_reset : std\_logic; -- nios2\_gen2\_0:debug\_reset\_request -> rst\_controller:reset\_in0

signal nios2\_gen2\_0\_data\_master\_readdata : std\_logic\_vector(31 downto 0); -- mm\_interconnect\_0:nios2\_gen2\_0\_data\_master\_readdata -> nios2\_gen2\_0:d\_readdata

signal nios2\_gen2\_0\_data\_master\_waitrequest : std\_logic; -- mm\_interconnect\_0:nios2\_gen2\_0\_data\_master\_waitrequest -> nios2\_gen2\_0:d\_waitrequest

signal nios2\_gen2\_0\_data\_master\_debugaccess : std\_logic; -- nios2\_gen2\_0:debug\_mem\_slave\_debugaccess\_to\_roms -> mm\_interconnect\_0:nios2\_gen2\_0\_data\_master\_debugaccess

signal nios2\_gen2\_0\_data\_master\_address : std\_logic\_vector(17 downto 0); -- nios2\_gen2\_0:d\_address -> mm\_interconnect\_0:nios2\_gen2\_0\_data\_master\_address

signal nios2\_gen2\_0\_data\_master\_byteenable : std\_logic\_vector(3 downto 0); -- nios2\_gen2\_0:d\_byteenable -> mm\_interconnect\_0:nios2\_gen2\_0\_data\_master\_byteenable

signal nios2\_gen2\_0\_data\_master\_read : std\_logic; -- nios2\_gen2\_0:d\_read -> mm\_interconnect\_0:nios2\_gen2\_0\_data\_master\_read

signal nios2\_gen2\_0\_data\_master\_write : std\_logic; -- nios2\_gen2\_0:d\_write -> mm\_interconnect\_0:nios2\_gen2\_0\_data\_master\_write

signal nios2\_gen2\_0\_data\_master\_writedata : std\_logic\_vector(31 downto 0); -- nios2\_gen2\_0:d\_writedata -> mm\_interconnect\_0:nios2\_gen2\_0\_data\_master\_writedata

signal nios2\_gen2\_0\_instruction\_master\_readdata : std\_logic\_vector(31 downto 0); -- mm\_interconnect\_0:nios2\_gen2\_0\_instruction\_master\_readdata -> nios2\_gen2\_0:i\_readdata

signal nios2\_gen2\_0\_instruction\_master\_waitrequest : std\_logic; -- mm\_interconnect\_0:nios2\_gen2\_0\_instruction\_master\_waitrequest -> nios2\_gen2\_0:i\_waitrequest

signal nios2\_gen2\_0\_instruction\_master\_address : std\_logic\_vector(17 downto 0); -- nios2\_gen2\_0:i\_address -> mm\_interconnect\_0:nios2\_gen2\_0\_instruction\_master\_address

signal nios2\_gen2\_0\_instruction\_master\_read : std\_logic; -- nios2\_gen2\_0:i\_read -> mm\_interconnect\_0:nios2\_gen2\_0\_instruction\_master\_read

signal mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_chipselect : std\_logic; -- mm\_interconnect\_0:jtag\_uart\_0\_avalon\_jtag\_slave\_chipselect -> jtag\_uart\_0:av\_chipselect

signal mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_readdata : std\_logic\_vector(31 downto 0); -- jtag\_uart\_0:av\_readdata -> mm\_interconnect\_0:jtag\_uart\_0\_avalon\_jtag\_slave\_readdata

signal mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_waitrequest : std\_logic; -- jtag\_uart\_0:av\_waitrequest -> mm\_interconnect\_0:jtag\_uart\_0\_avalon\_jtag\_slave\_waitrequest

signal mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_address : std\_logic\_vector(0 downto 0); -- mm\_interconnect\_0:jtag\_uart\_0\_avalon\_jtag\_slave\_address -> jtag\_uart\_0:av\_address

signal mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_read : std\_logic; -- mm\_interconnect\_0:jtag\_uart\_0\_avalon\_jtag\_slave\_read -> mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_read:in

signal mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_write : std\_logic; -- mm\_interconnect\_0:jtag\_uart\_0\_avalon\_jtag\_slave\_write -> mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_write:in

signal mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_writedata : std\_logic\_vector(31 downto 0); -- mm\_interconnect\_0:jtag\_uart\_0\_avalon\_jtag\_slave\_writedata -> jtag\_uart\_0:av\_writedata

signal mm\_interconnect\_0\_nios2\_gen2\_0\_debug\_mem\_slave\_readdata : std\_logic\_vector(31 downto 0); -- nios2\_gen2\_0:debug\_mem\_slave\_readdata -> mm\_interconnect\_0:nios2\_gen2\_0\_debug\_mem\_slave\_readdata

signal mm\_interconnect\_0\_nios2\_gen2\_0\_debug\_mem\_slave\_waitrequest : std\_logic; -- nios2\_gen2\_0:debug\_mem\_slave\_waitrequest -> mm\_interconnect\_0:nios2\_gen2\_0\_debug\_mem\_slave\_waitrequest

signal mm\_interconnect\_0\_nios2\_gen2\_0\_debug\_mem\_slave\_debugaccess : std\_logic; -- mm\_interconnect\_0:nios2\_gen2\_0\_debug\_mem\_slave\_debugaccess -> nios2\_gen2\_0:debug\_mem\_slave\_debugaccess

signal mm\_interconnect\_0\_nios2\_gen2\_0\_debug\_mem\_slave\_address : std\_logic\_vector(8 downto 0); -- mm\_interconnect\_0:nios2\_gen2\_0\_debug\_mem\_slave\_address -> nios2\_gen2\_0:debug\_mem\_slave\_address

signal mm\_interconnect\_0\_nios2\_gen2\_0\_debug\_mem\_slave\_read : std\_logic; -- mm\_interconnect\_0:nios2\_gen2\_0\_debug\_mem\_slave\_read -> nios2\_gen2\_0:debug\_mem\_slave\_read

signal mm\_interconnect\_0\_nios2\_gen2\_0\_debug\_mem\_slave\_byteenable : std\_logic\_vector(3 downto 0); -- mm\_interconnect\_0:nios2\_gen2\_0\_debug\_mem\_slave\_byteenable -> nios2\_gen2\_0:debug\_mem\_slave\_byteenable

signal mm\_interconnect\_0\_nios2\_gen2\_0\_debug\_mem\_slave\_write : std\_logic; -- mm\_interconnect\_0:nios2\_gen2\_0\_debug\_mem\_slave\_write -> nios2\_gen2\_0:debug\_mem\_slave\_write

signal mm\_interconnect\_0\_nios2\_gen2\_0\_debug\_mem\_slave\_writedata : std\_logic\_vector(31 downto 0); -- mm\_interconnect\_0:nios2\_gen2\_0\_debug\_mem\_slave\_writedata -> nios2\_gen2\_0:debug\_mem\_slave\_writedata

signal mm\_interconnect\_0\_onchip\_memory2\_0\_s1\_chipselect : std\_logic; -- mm\_interconnect\_0:onchip\_memory2\_0\_s1\_chipselect -> onchip\_memory2\_0:chipselect

signal mm\_interconnect\_0\_onchip\_memory2\_0\_s1\_readdata : std\_logic\_vector(31 downto 0); -- onchip\_memory2\_0:readdata -> mm\_interconnect\_0:onchip\_memory2\_0\_s1\_readdata

signal mm\_interconnect\_0\_onchip\_memory2\_0\_s1\_address : std\_logic\_vector(13 downto 0); -- mm\_interconnect\_0:onchip\_memory2\_0\_s1\_address -> onchip\_memory2\_0:address

signal mm\_interconnect\_0\_onchip\_memory2\_0\_s1\_byteenable : std\_logic\_vector(3 downto 0); -- mm\_interconnect\_0:onchip\_memory2\_0\_s1\_byteenable -> onchip\_memory2\_0:byteenable

signal mm\_interconnect\_0\_onchip\_memory2\_0\_s1\_write : std\_logic; -- mm\_interconnect\_0:onchip\_memory2\_0\_s1\_write -> onchip\_memory2\_0:write

signal mm\_interconnect\_0\_onchip\_memory2\_0\_s1\_writedata : std\_logic\_vector(31 downto 0); -- mm\_interconnect\_0:onchip\_memory2\_0\_s1\_writedata -> onchip\_memory2\_0:writedata

signal mm\_interconnect\_0\_onchip\_memory2\_0\_s1\_clken : std\_logic; -- mm\_interconnect\_0:onchip\_memory2\_0\_s1\_clken -> onchip\_memory2\_0:clken

signal mm\_interconnect\_0\_readval\_s1\_readdata : std\_logic\_vector(31 downto 0); -- readval:readdata -> mm\_interconnect\_0:readval\_s1\_readdata

signal mm\_interconnect\_0\_readval\_s1\_address : std\_logic\_vector(1 downto 0); -- mm\_interconnect\_0:readval\_s1\_address -> readval:address

signal mm\_interconnect\_0\_nextval\_s1\_chipselect : std\_logic; -- mm\_interconnect\_0:nextval\_s1\_chipselect -> nextval:chipselect

signal mm\_interconnect\_0\_nextval\_s1\_readdata : std\_logic\_vector(31 downto 0); -- nextval:readdata -> mm\_interconnect\_0:nextval\_s1\_readdata

signal mm\_interconnect\_0\_nextval\_s1\_address : std\_logic\_vector(1 downto 0); -- mm\_interconnect\_0:nextval\_s1\_address -> nextval:address

signal mm\_interconnect\_0\_nextval\_s1\_write : std\_logic; -- mm\_interconnect\_0:nextval\_s1\_write -> mm\_interconnect\_0\_nextval\_s1\_write:in

signal mm\_interconnect\_0\_nextval\_s1\_writedata : std\_logic\_vector(31 downto 0); -- mm\_interconnect\_0:nextval\_s1\_writedata -> nextval:writedata

signal mm\_interconnect\_0\_writeval\_s1\_chipselect : std\_logic; -- mm\_interconnect\_0:writeval\_s1\_chipselect -> writeval:chipselect

signal mm\_interconnect\_0\_writeval\_s1\_readdata : std\_logic\_vector(31 downto 0); -- writeval:readdata -> mm\_interconnect\_0:writeval\_s1\_readdata

signal mm\_interconnect\_0\_writeval\_s1\_address : std\_logic\_vector(1 downto 0); -- mm\_interconnect\_0:writeval\_s1\_address -> writeval:address

signal mm\_interconnect\_0\_writeval\_s1\_write : std\_logic; -- mm\_interconnect\_0:writeval\_s1\_write -> mm\_interconnect\_0\_writeval\_s1\_write:in

signal mm\_interconnect\_0\_writeval\_s1\_writedata : std\_logic\_vector(31 downto 0); -- mm\_interconnect\_0:writeval\_s1\_writedata -> writeval:writedata

signal mm\_interconnect\_0\_nextwriteval\_s1\_chipselect : std\_logic; -- mm\_interconnect\_0:nextwriteval\_s1\_chipselect -> nextwriteval:chipselect

signal mm\_interconnect\_0\_nextwriteval\_s1\_readdata : std\_logic\_vector(31 downto 0); -- nextwriteval:readdata -> mm\_interconnect\_0:nextwriteval\_s1\_readdata

signal mm\_interconnect\_0\_nextwriteval\_s1\_address : std\_logic\_vector(1 downto 0); -- mm\_interconnect\_0:nextwriteval\_s1\_address -> nextwriteval:address

signal mm\_interconnect\_0\_nextwriteval\_s1\_write : std\_logic; -- mm\_interconnect\_0:nextwriteval\_s1\_write -> mm\_interconnect\_0\_nextwriteval\_s1\_write:in

signal mm\_interconnect\_0\_nextwriteval\_s1\_writedata : std\_logic\_vector(31 downto 0); -- mm\_interconnect\_0:nextwriteval\_s1\_writedata -> nextwriteval:writedata

signal irq\_mapper\_receiver0\_irq : std\_logic; -- jtag\_uart\_0:av\_irq -> irq\_mapper:receiver0\_irq

signal nios2\_gen2\_0\_irq\_irq : std\_logic\_vector(31 downto 0); -- irq\_mapper:sender\_irq -> nios2\_gen2\_0:irq

signal rst\_controller\_reset\_out\_reset : std\_logic; -- rst\_controller:reset\_out -> [irq\_mapper:reset, mm\_interconnect\_0:nios2\_gen2\_0\_reset\_reset\_bridge\_in\_reset\_reset, onchip\_memory2\_0:reset, rst\_controller\_reset\_out\_reset:in, rst\_translator:in\_reset]

signal rst\_controller\_reset\_out\_reset\_req : std\_logic; -- rst\_controller:reset\_req -> [nios2\_gen2\_0:reset\_req, onchip\_memory2\_0:reset\_req, rst\_translator:reset\_req\_in]

signal mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_read\_ports\_inv : std\_logic; -- mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_read:inv -> jtag\_uart\_0:av\_read\_n

signal mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_write\_ports\_inv : std\_logic; -- mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_write:inv -> jtag\_uart\_0:av\_write\_n

signal mm\_interconnect\_0\_nextval\_s1\_write\_ports\_inv : std\_logic; -- mm\_interconnect\_0\_nextval\_s1\_write:inv -> nextval:write\_n

signal mm\_interconnect\_0\_writeval\_s1\_write\_ports\_inv : std\_logic; -- mm\_interconnect\_0\_writeval\_s1\_write:inv -> writeval:write\_n

signal mm\_interconnect\_0\_nextwriteval\_s1\_write\_ports\_inv : std\_logic; -- mm\_interconnect\_0\_nextwriteval\_s1\_write:inv -> nextwriteval:write\_n

signal rst\_controller\_reset\_out\_reset\_ports\_inv : std\_logic; -- rst\_controller\_reset\_out\_reset:inv -> [jtag\_uart\_0:rst\_n, nextval:reset\_n, nextwriteval:reset\_n, nios2\_gen2\_0:reset\_n, readval:reset\_n, writeval:reset\_n]

begin

jtag\_uart\_0 : component MATRIX\_CALCULATOR\_jtag\_uart\_0

port map (

clk => clk\_clk, -- clk.clk

rst\_n => rst\_controller\_reset\_out\_reset\_ports\_inv, -- reset.reset\_n

av\_chipselect => mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_chipselect, -- avalon\_jtag\_slave.chipselect

av\_address => mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_address(0), -- .address

av\_read\_n => mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_read\_ports\_inv, -- .read\_n

av\_readdata => mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_readdata, -- .readdata

av\_write\_n => mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_write\_ports\_inv, -- .write\_n

av\_writedata => mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_writedata, -- .writedata

av\_waitrequest => mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_waitrequest, -- .waitrequest

av\_irq => irq\_mapper\_receiver0\_irq -- irq.irq

);

nextval : component MATRIX\_CALCULATOR\_nextval

port map (

clk => clk\_clk, -- clk.clk

reset\_n => rst\_controller\_reset\_out\_reset\_ports\_inv, -- reset.reset\_n

address => mm\_interconnect\_0\_nextval\_s1\_address, -- s1.address

write\_n => mm\_interconnect\_0\_nextval\_s1\_write\_ports\_inv, -- .write\_n

writedata => mm\_interconnect\_0\_nextval\_s1\_writedata, -- .writedata

chipselect => mm\_interconnect\_0\_nextval\_s1\_chipselect, -- .chipselect

readdata => mm\_interconnect\_0\_nextval\_s1\_readdata, -- .readdata

out\_port => nextval\_external\_connection\_export -- external\_connection.export

);

nextwriteval : component MATRIX\_CALCULATOR\_nextval

port map (

clk => clk\_clk, -- clk.clk

reset\_n => rst\_controller\_reset\_out\_reset\_ports\_inv, -- reset.reset\_n

address => mm\_interconnect\_0\_nextwriteval\_s1\_address, -- s1.address

write\_n => mm\_interconnect\_0\_nextwriteval\_s1\_write\_ports\_inv, -- .write\_n

writedata => mm\_interconnect\_0\_nextwriteval\_s1\_writedata, -- .writedata

chipselect => mm\_interconnect\_0\_nextwriteval\_s1\_chipselect, -- .chipselect

readdata => mm\_interconnect\_0\_nextwriteval\_s1\_readdata, -- .readdata

out\_port => nextwriteval\_external\_connection\_export -- external\_connection.export

);

nios2\_gen2\_0 : component MATRIX\_CALCULATOR\_nios2\_gen2\_0

port map (

clk => clk\_clk, -- clk.clk

reset\_n => rst\_controller\_reset\_out\_reset\_ports\_inv, -- reset.reset\_n

reset\_req => rst\_controller\_reset\_out\_reset\_req, -- .reset\_req

d\_address => nios2\_gen2\_0\_data\_master\_address, -- data\_master.address

d\_byteenable => nios2\_gen2\_0\_data\_master\_byteenable, -- .byteenable

d\_read => nios2\_gen2\_0\_data\_master\_read, -- .read

d\_readdata => nios2\_gen2\_0\_data\_master\_readdata, -- .readdata

d\_waitrequest => nios2\_gen2\_0\_data\_master\_waitrequest, -- .waitrequest

d\_write => nios2\_gen2\_0\_data\_master\_write, -- .write

d\_writedata => nios2\_gen2\_0\_data\_master\_writedata, -- .writedata

debug\_mem\_slave\_debugaccess\_to\_roms => nios2\_gen2\_0\_data\_master\_debugaccess, -- .debugaccess

i\_address => nios2\_gen2\_0\_instruction\_master\_address, -- instruction\_master.address

i\_read => nios2\_gen2\_0\_instruction\_master\_read, -- .read

i\_readdata => nios2\_gen2\_0\_instruction\_master\_readdata, -- .readdata

i\_waitrequest => nios2\_gen2\_0\_instruction\_master\_waitrequest, -- .waitrequest

irq => nios2\_gen2\_0\_irq\_irq, -- irq.irq

debug\_reset\_request => nios2\_gen2\_0\_debug\_reset\_request\_reset, -- debug\_reset\_request.reset

debug\_mem\_slave\_address => mm\_interconnect\_0\_nios2\_gen2\_0\_debug\_mem\_slave\_address, -- debug\_mem\_slave.address

debug\_mem\_slave\_byteenable => mm\_interconnect\_0\_nios2\_gen2\_0\_debug\_mem\_slave\_byteenable, -- .byteenable

debug\_mem\_slave\_debugaccess => mm\_interconnect\_0\_nios2\_gen2\_0\_debug\_mem\_slave\_debugaccess, -- .debugaccess

debug\_mem\_slave\_read => mm\_interconnect\_0\_nios2\_gen2\_0\_debug\_mem\_slave\_read, -- .read

debug\_mem\_slave\_readdata => mm\_interconnect\_0\_nios2\_gen2\_0\_debug\_mem\_slave\_readdata, -- .readdata

debug\_mem\_slave\_waitrequest => mm\_interconnect\_0\_nios2\_gen2\_0\_debug\_mem\_slave\_waitrequest, -- .waitrequest

debug\_mem\_slave\_write => mm\_interconnect\_0\_nios2\_gen2\_0\_debug\_mem\_slave\_write, -- .write

debug\_mem\_slave\_writedata => mm\_interconnect\_0\_nios2\_gen2\_0\_debug\_mem\_slave\_writedata, -- .writedata

dummy\_ci\_port => open -- custom\_instruction\_master.readra

);

onchip\_memory2\_0 : component MATRIX\_CALCULATOR\_onchip\_memory2\_0

port map (

clk => clk\_clk, -- clk1.clk

address => mm\_interconnect\_0\_onchip\_memory2\_0\_s1\_address, -- s1.address

clken => mm\_interconnect\_0\_onchip\_memory2\_0\_s1\_clken, -- .clken

chipselect => mm\_interconnect\_0\_onchip\_memory2\_0\_s1\_chipselect, -- .chipselect

write => mm\_interconnect\_0\_onchip\_memory2\_0\_s1\_write, -- .write

readdata => mm\_interconnect\_0\_onchip\_memory2\_0\_s1\_readdata, -- .readdata

writedata => mm\_interconnect\_0\_onchip\_memory2\_0\_s1\_writedata, -- .writedata

byteenable => mm\_interconnect\_0\_onchip\_memory2\_0\_s1\_byteenable, -- .byteenable

reset => rst\_controller\_reset\_out\_reset, -- reset1.reset

reset\_req => rst\_controller\_reset\_out\_reset\_req, -- .reset\_req

freeze => '0' -- (terminated)

);

readval : component MATRIX\_CALCULATOR\_readval

port map (

clk => clk\_clk, -- clk.clk

reset\_n => rst\_controller\_reset\_out\_reset\_ports\_inv, -- reset.reset\_n

address => mm\_interconnect\_0\_readval\_s1\_address, -- s1.address

readdata => mm\_interconnect\_0\_readval\_s1\_readdata, -- .readdata

in\_port => readval\_external\_connection\_export -- external\_connection.export

);

writeval : component MATRIX\_CALCULATOR\_nextval

port map (

clk => clk\_clk, -- clk.clk

reset\_n => rst\_controller\_reset\_out\_reset\_ports\_inv, -- reset.reset\_n

address => mm\_interconnect\_0\_writeval\_s1\_address, -- s1.address

write\_n => mm\_interconnect\_0\_writeval\_s1\_write\_ports\_inv, -- .write\_n

writedata => mm\_interconnect\_0\_writeval\_s1\_writedata, -- .writedata

chipselect => mm\_interconnect\_0\_writeval\_s1\_chipselect, -- .chipselect

readdata => mm\_interconnect\_0\_writeval\_s1\_readdata, -- .readdata

out\_port => writeval\_external\_connection\_export -- external\_connection.export

);

mm\_interconnect\_0 : component MATRIX\_CALCULATOR\_mm\_interconnect\_0

port map (

clk\_0\_clk\_clk => clk\_clk, -- clk\_0\_clk.clk

nios2\_gen2\_0\_reset\_reset\_bridge\_in\_reset\_reset => rst\_controller\_reset\_out\_reset, -- nios2\_gen2\_0\_reset\_reset\_bridge\_in\_reset.reset

nios2\_gen2\_0\_data\_master\_address => nios2\_gen2\_0\_data\_master\_address, -- nios2\_gen2\_0\_data\_master.address

nios2\_gen2\_0\_data\_master\_waitrequest => nios2\_gen2\_0\_data\_master\_waitrequest, -- .waitrequest

nios2\_gen2\_0\_data\_master\_byteenable => nios2\_gen2\_0\_data\_master\_byteenable, -- .byteenable

nios2\_gen2\_0\_data\_master\_read => nios2\_gen2\_0\_data\_master\_read, -- .read

nios2\_gen2\_0\_data\_master\_readdata => nios2\_gen2\_0\_data\_master\_readdata, -- .readdata

nios2\_gen2\_0\_data\_master\_write => nios2\_gen2\_0\_data\_master\_write, -- .write

nios2\_gen2\_0\_data\_master\_writedata => nios2\_gen2\_0\_data\_master\_writedata, -- .writedata

nios2\_gen2\_0\_data\_master\_debugaccess => nios2\_gen2\_0\_data\_master\_debugaccess, -- .debugaccess

nios2\_gen2\_0\_instruction\_master\_address => nios2\_gen2\_0\_instruction\_master\_address, -- nios2\_gen2\_0\_instruction\_master.address

nios2\_gen2\_0\_instruction\_master\_waitrequest => nios2\_gen2\_0\_instruction\_master\_waitrequest, -- .waitrequest

nios2\_gen2\_0\_instruction\_master\_read => nios2\_gen2\_0\_instruction\_master\_read, -- .read

nios2\_gen2\_0\_instruction\_master\_readdata => nios2\_gen2\_0\_instruction\_master\_readdata, -- .readdata

jtag\_uart\_0\_avalon\_jtag\_slave\_address => mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_address, -- jtag\_uart\_0\_avalon\_jtag\_slave.address

jtag\_uart\_0\_avalon\_jtag\_slave\_write => mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_write, -- .write

jtag\_uart\_0\_avalon\_jtag\_slave\_read => mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_read, -- .read

jtag\_uart\_0\_avalon\_jtag\_slave\_readdata => mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_readdata, -- .readdata

jtag\_uart\_0\_avalon\_jtag\_slave\_writedata => mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_writedata, -- .writedata

jtag\_uart\_0\_avalon\_jtag\_slave\_waitrequest => mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_waitrequest, -- .waitrequest

jtag\_uart\_0\_avalon\_jtag\_slave\_chipselect => mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_chipselect, -- .chipselect

nextval\_s1\_address => mm\_interconnect\_0\_nextval\_s1\_address, -- nextval\_s1.address

nextval\_s1\_write => mm\_interconnect\_0\_nextval\_s1\_write, -- .write

nextval\_s1\_readdata => mm\_interconnect\_0\_nextval\_s1\_readdata, -- .readdata

nextval\_s1\_writedata => mm\_interconnect\_0\_nextval\_s1\_writedata, -- .writedata

nextval\_s1\_chipselect => mm\_interconnect\_0\_nextval\_s1\_chipselect, -- .chipselect

nextwriteval\_s1\_address => mm\_interconnect\_0\_nextwriteval\_s1\_address, -- nextwriteval\_s1.address

nextwriteval\_s1\_write => mm\_interconnect\_0\_nextwriteval\_s1\_write, -- .write

nextwriteval\_s1\_readdata => mm\_interconnect\_0\_nextwriteval\_s1\_readdata, -- .readdata

nextwriteval\_s1\_writedata => mm\_interconnect\_0\_nextwriteval\_s1\_writedata, -- .writedata

nextwriteval\_s1\_chipselect => mm\_interconnect\_0\_nextwriteval\_s1\_chipselect, -- .chipselect

nios2\_gen2\_0\_debug\_mem\_slave\_address => mm\_interconnect\_0\_nios2\_gen2\_0\_debug\_mem\_slave\_address, -- nios2\_gen2\_0\_debug\_mem\_slave.address

nios2\_gen2\_0\_debug\_mem\_slave\_write => mm\_interconnect\_0\_nios2\_gen2\_0\_debug\_mem\_slave\_write, -- .write

nios2\_gen2\_0\_debug\_mem\_slave\_read => mm\_interconnect\_0\_nios2\_gen2\_0\_debug\_mem\_slave\_read, -- .read

nios2\_gen2\_0\_debug\_mem\_slave\_readdata => mm\_interconnect\_0\_nios2\_gen2\_0\_debug\_mem\_slave\_readdata, -- .readdata

nios2\_gen2\_0\_debug\_mem\_slave\_writedata => mm\_interconnect\_0\_nios2\_gen2\_0\_debug\_mem\_slave\_writedata, -- .writedata

nios2\_gen2\_0\_debug\_mem\_slave\_byteenable => mm\_interconnect\_0\_nios2\_gen2\_0\_debug\_mem\_slave\_byteenable, -- .byteenable

nios2\_gen2\_0\_debug\_mem\_slave\_waitrequest => mm\_interconnect\_0\_nios2\_gen2\_0\_debug\_mem\_slave\_waitrequest, -- .waitrequest

nios2\_gen2\_0\_debug\_mem\_slave\_debugaccess => mm\_interconnect\_0\_nios2\_gen2\_0\_debug\_mem\_slave\_debugaccess, -- .debugaccess

onchip\_memory2\_0\_s1\_address => mm\_interconnect\_0\_onchip\_memory2\_0\_s1\_address, -- onchip\_memory2\_0\_s1.address

onchip\_memory2\_0\_s1\_write => mm\_interconnect\_0\_onchip\_memory2\_0\_s1\_write, -- .write

onchip\_memory2\_0\_s1\_readdata => mm\_interconnect\_0\_onchip\_memory2\_0\_s1\_readdata, -- .readdata

onchip\_memory2\_0\_s1\_writedata => mm\_interconnect\_0\_onchip\_memory2\_0\_s1\_writedata, -- .writedata

onchip\_memory2\_0\_s1\_byteenable => mm\_interconnect\_0\_onchip\_memory2\_0\_s1\_byteenable, -- .byteenable

onchip\_memory2\_0\_s1\_chipselect => mm\_interconnect\_0\_onchip\_memory2\_0\_s1\_chipselect, -- .chipselect

onchip\_memory2\_0\_s1\_clken => mm\_interconnect\_0\_onchip\_memory2\_0\_s1\_clken, -- .clken

readval\_s1\_address => mm\_interconnect\_0\_readval\_s1\_address, -- readval\_s1.address

readval\_s1\_readdata => mm\_interconnect\_0\_readval\_s1\_readdata, -- .readdata

writeval\_s1\_address => mm\_interconnect\_0\_writeval\_s1\_address, -- writeval\_s1.address

writeval\_s1\_write => mm\_interconnect\_0\_writeval\_s1\_write, -- .write

writeval\_s1\_readdata => mm\_interconnect\_0\_writeval\_s1\_readdata, -- .readdata

writeval\_s1\_writedata => mm\_interconnect\_0\_writeval\_s1\_writedata, -- .writedata

writeval\_s1\_chipselect => mm\_interconnect\_0\_writeval\_s1\_chipselect -- .chipselect

);

irq\_mapper : component MATRIX\_CALCULATOR\_irq\_mapper

port map (

clk => clk\_clk, -- clk.clk

reset => rst\_controller\_reset\_out\_reset, -- clk\_reset.reset

receiver0\_irq => irq\_mapper\_receiver0\_irq, -- receiver0.irq

sender\_irq => nios2\_gen2\_0\_irq\_irq -- sender.irq

);

rst\_controller : component altera\_reset\_controller

generic map (

NUM\_RESET\_INPUTS => 1,

OUTPUT\_RESET\_SYNC\_EDGES => "deassert",

SYNC\_DEPTH => 2,

RESET\_REQUEST\_PRESENT => 1,

RESET\_REQ\_WAIT\_TIME => 1,

MIN\_RST\_ASSERTION\_TIME => 3,

RESET\_REQ\_EARLY\_DSRT\_TIME => 1,

USE\_RESET\_REQUEST\_IN0 => 0,

USE\_RESET\_REQUEST\_IN1 => 0,

USE\_RESET\_REQUEST\_IN2 => 0,

USE\_RESET\_REQUEST\_IN3 => 0,

USE\_RESET\_REQUEST\_IN4 => 0,

USE\_RESET\_REQUEST\_IN5 => 0,

USE\_RESET\_REQUEST\_IN6 => 0,

USE\_RESET\_REQUEST\_IN7 => 0,

USE\_RESET\_REQUEST\_IN8 => 0,

USE\_RESET\_REQUEST\_IN9 => 0,

USE\_RESET\_REQUEST\_IN10 => 0,

USE\_RESET\_REQUEST\_IN11 => 0,

USE\_RESET\_REQUEST\_IN12 => 0,

USE\_RESET\_REQUEST\_IN13 => 0,

USE\_RESET\_REQUEST\_IN14 => 0,

USE\_RESET\_REQUEST\_IN15 => 0,

ADAPT\_RESET\_REQUEST => 0

)

port map (

reset\_in0 => nios2\_gen2\_0\_debug\_reset\_request\_reset, -- reset\_in0.reset

clk => clk\_clk, -- clk.clk

reset\_out => rst\_controller\_reset\_out\_reset, -- reset\_out.reset

reset\_req => rst\_controller\_reset\_out\_reset\_req, -- .reset\_req

reset\_req\_in0 => '0', -- (terminated)

reset\_in1 => '0', -- (terminated)

reset\_req\_in1 => '0', -- (terminated)

reset\_in2 => '0', -- (terminated)

reset\_req\_in2 => '0', -- (terminated)

reset\_in3 => '0', -- (terminated)

reset\_req\_in3 => '0', -- (terminated)

reset\_in4 => '0', -- (terminated)

reset\_req\_in4 => '0', -- (terminated)

reset\_in5 => '0', -- (terminated)

reset\_req\_in5 => '0', -- (terminated)

reset\_in6 => '0', -- (terminated)

reset\_req\_in6 => '0', -- (terminated)

reset\_in7 => '0', -- (terminated)

reset\_req\_in7 => '0', -- (terminated)

reset\_in8 => '0', -- (terminated)

reset\_req\_in8 => '0', -- (terminated)

reset\_in9 => '0', -- (terminated)

reset\_req\_in9 => '0', -- (terminated)

reset\_in10 => '0', -- (terminated)

reset\_req\_in10 => '0', -- (terminated)

reset\_in11 => '0', -- (terminated)

reset\_req\_in11 => '0', -- (terminated)

reset\_in12 => '0', -- (terminated)

reset\_req\_in12 => '0', -- (terminated)

reset\_in13 => '0', -- (terminated)

reset\_req\_in13 => '0', -- (terminated)

reset\_in14 => '0', -- (terminated)

reset\_req\_in14 => '0', -- (terminated)

reset\_in15 => '0', -- (terminated)

reset\_req\_in15 => '0' -- (terminated)

);

mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_read\_ports\_inv <= not mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_read;

mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_write\_ports\_inv <= not mm\_interconnect\_0\_jtag\_uart\_0\_avalon\_jtag\_slave\_write;

mm\_interconnect\_0\_nextval\_s1\_write\_ports\_inv <= not mm\_interconnect\_0\_nextval\_s1\_write;

mm\_interconnect\_0\_writeval\_s1\_write\_ports\_inv <= not mm\_interconnect\_0\_writeval\_s1\_write;

mm\_interconnect\_0\_nextwriteval\_s1\_write\_ports\_inv <= not mm\_interconnect\_0\_nextwriteval\_s1\_write;

rst\_controller\_reset\_out\_reset\_ports\_inv <= not rst\_controller\_reset\_out\_reset;

end architecture rtl; -- of MATRIX\_CALCULATOR

**VHDL code for UART Decoder**

LIBRARY ieee;

USE ieee.std\_logic\_1164.all;

USE ieee.numeric\_std.all;

ENTITY Uart\_Decoder IS

GENERIC(

BaudRate : IN INTEGER := 9600;

ClockRate : IN INTEGER := 50\_000\_000

);

PORT(

Clk, Rx : IN STD\_LOGIC;

Complete : OUT STD\_LOGIC;

Data : OUT STD\_LOGIC\_VECTOR(7 DOWNTO 0)

);

END Uart\_Decoder;

ARCHITECTURE Behavior OF Uart\_Decoder IS

SIGNAL started : STD\_LOGIC; -- Whether we've started or not

SIGNAL bit\_location : Integer RANGE 0 TO 9 := 0; -- Where to save the bit

SIGNAL data\_reg : STD\_LOGIC\_VECTOR(9 DOWNTO 0); -- Local copy of the data, including start and stop bit

BEGIN

PROCESS (Rx, bit\_location)

BEGIN

IF bit\_location = 9 THEN

started <= '0';

ELSIF Rx = '0' AND Rx'event THEN

started <= '1';

END IF;

END PROCESS;

PROCESS (Clk, Rx, started)

VARIABLE counter : Integer RANGE 0 TO ((ClockRate / BaudRate)+1) := 0;

BEGIN

IF Clk = '1' AND Clk'event THEN

IF started = '1' THEN

counter := counter + 1;

IF counter = ((ClockRate) / BaudRate) THEN

counter := 0;

bit\_location <= bit\_location + 1;

ELSIF counter = (ClockRate / (BaudRate \* 2)) THEN

data\_reg(bit\_location) <= Rx;

END IF;

ELSE

bit\_location <= 0;

counter := 0;

END IF;

END IF;

END PROCESS;

Complete <= NOT started;

Data <= data\_reg(8 DOWNTO 1);

END Behavior;

**VHDL code for UART Transmitter:**

LIBRARY ieee;

USE ieee.std\_logic\_1164.all;

USE ieee.numeric\_std.all;

ENTITY Uart\_Transmitter IS

GENERIC(

BaudRate : IN INTEGER := 9600;

ClockRate : IN INTEGER := 50\_000\_000

);

PORT(

Clk, Send : IN STD\_LOGIC;

Data : IN STD\_LOGIC\_VECTOR(7 DOWNTO 0);

Tx : OUT STD\_LOGIC

);

END Uart\_Transmitter;

ARCHITECTURE Behavior OF Uart\_Transmitter IS

SIGNAL started : STD\_LOGIC; -- Whether we've started or not

SIGNAL bit\_location : Integer RANGE 0 TO 9 := 0; -- Where to save the bit

BEGIN

PROCESS (Send, bit\_location)

BEGIN

IF bit\_location = 9 THEN

started <= '0';

ELSIF Send = '1' AND Send'event THEN

started <= '1';

END IF;

END PROCESS;

PROCESS (Clk, started, Data)

VARIABLE counter : Integer RANGE 0 TO ((ClockRate\*2) / BaudRate) := 0;

BEGIN

IF Clk = '1' AND Clk'event THEN

IF started = '1' THEN

counter := counter + 1;

IF counter = ((ClockRate) / BaudRate) THEN

counter := 0;

bit\_location <= bit\_location + 1;

ELSIF counter = (ClockRate / (BaudRate\*2)) THEN

-- Send the start bit

IF(bit\_location = 0) THEN

Tx <= '0';

-- Send data bits

ELSIF bit\_location > 0 AND bit\_location < 9 THEN

Tx <= Data(bit\_location - 1);

-- Send the stop bit

ELSE

Tx <= '1';

END IF;

END IF;

ELSE

bit\_location <= 0;

counter := 0;

Tx <= '1';

END IF;

END IF;

END PROCESS;

END Behavior;

**VHDL code for FIFO:**

library IEEE;

use IEEE.STD\_LOGIC\_1164.ALL;

use IEEE.STD\_LOGIC\_UNSIGNED.ALL;

entity FIFO is

generic (num : in integer := 128);

port ( complete : in std\_logic;

data\_in : in std\_logic\_vector(7 downto 0);

pop, clear : in std\_logic;

data\_out : out std\_logic\_vector (7 downto 0));

end FIFO;

architecture behavior of FIFO is

type fifo\_size is array (0 to num-1) of std\_logic\_vector (7 downto 0);

signal mem : fifo\_size; --declaring 32 buffers with 8 bit wide

signal stop : integer range 0 to num-1 := 0;

signal start : integer range 0 to num-1 := 0;

begin

--at the rising edge of complete

--data is received into buffer

--if index of mem reaches num (32) the index is changed ot 0

process(complete, pop, data\_in, clear)

variable newStart : integer range 0 to num-1;

variable newEnd : integer range 0 to num-1;

variable toSend : std\_logic\_vector(7 downto 0);

begin

if clear = '1' then

start <= 0;

stop <= 0;

else

if complete'event and complete = '1' then

newEnd := stop - 2;

if not(start = newEnd) then

start <= start + 1;

if(start = num-1) then

mem(0) <= data\_in;

else

mem(start + 1) <= data\_in;

end if;

end if;

end if;

--assuming pop as a 1 bit input

--first value from the queue is stored into data\_out object

--queue is updated

newStart := start;

if pop'event and pop = '1' then

if not (newStart = stop) then

stop <= stop + 1;

end if;

end if;

end if;

-- Get the current head of the ring buffer if we're not empty

if not (start = stop) then

if(stop = num - 1) then

toSend := mem(0);

else

toSend := mem(stop + 1);

end if;

else

toSend := "00000000";

end if;

data\_out <= toSend;

end process;

end;

**Nios C code:**

//declaration of header files

#include "sys/alt\_stdio.h"

#include "stdlib.h"

#include "stdio.h"

#include "math.h"

#include "stdint.h"

#include "io.h"

#include "altera\_avalon\_pio\_regs.h"

#include "string.h"

/\*\*

\*\*@brief – sends an indicator to UART Tx that next value is ready to be displayed on the terminal

\*/

void next\_write()

{

uint8\_t \*next;

next = (uint8\_t \*)0x00021000;

\*next = 0;

for(volatile uint32\_t i=0; i<500000;i++);

\*next = 1;

for(volatile uint32\_t i=0; i<500000;i++);

}

/\*\*

\*\*@brief – writeByte and writeString functions fetch the value to be displayed into a Parallel IO with address 0x00021010

\*the value from the parallel IO is sent to UART Tx to display on the remote terminal

\*/

void writeByte(char c)

{

char \*toSend;

toSend = (char \*)0x00021010;

\*toSend = c;

}

void writeString(char\* str, int len)

{

for(int i = 0; i < len; ++i) {

writeByte(str[i]);

next\_write();

}

}

/\*\*

\*\*@brief – sends an indicator to FIFO that next value is ready to be stored into a parallel IO

\*/

void next\_from\_pio()

{

uint8\_t \*next;

next = (uint8\_t \*)0x00021020;

\*next = 0;

for(volatile uint32\_t i=0; i<500000;i++);

\*next = 1;

for(volatile uint32\_t i=0; i<500000;i++);

}

/\*\*

\*\*@brief – decodes the ascii value present in the Parallel IO( with address -0x00021030) into a number

\*calls next\_from\_pio() function inorder to store new value from FIFO into Parallel IO

\*‘,’ (comma) is used as a delimiter while reading data from FIFO

\*/

int decode\_ascii() {

int retval = 0;

while(1) {

char value = IORD\_ALTERA\_AVALON\_PIO\_DATA(0x00021030);

printf("%c\n", value);

if(value == ',') break;

if(value >= '0' && value <= '9')

{

retval \*= 10;

retval += value-'0';

}

next\_from\_pio();

}

next\_from\_pio();

return retval;

}

/\*

/\*\*

\* @brief Adds to matrices together

\*

\* @param a First matrix to add

\* @param b Second matrix to add

\* @param r1 Number of rows in a

\* @param c1 Number of columns in a

\* @param r2 Number of rows in b

\* @param c2 Number of columns in b

\*/

void matrix\_add(int\*\* a, int\*\* b, int r1, int c1, int r2, int c2)

{

int i,j,k,l;

int res[r1][c1];

if (r1 != r2 || c2 != c1)

{

char s[100];

char disp[]="Cannot be added";

sprintf(s,"%s",disp);

writeString(s, strlen(s));

}

else

{

for (i=0;i<r1;i++)

{

for(j=0;j<c1;j++)

{

res[i][j]= a[i][j] + b[i][j];

}

}

}

for (i=0;i<r1;i++)

{

for(j=0;j<c1;j++)

{

printf("res[%d][%d]= %d\n",i,j,res[i][j]);

char s[100];

sprintf(s,"%d,",res[i][j]);

writeString(s, strlen(s));

}

}

}

/\*\*

\* @brief performs matrix subtraction

\*

\* @param a First matrix

\* @param b Second matrix

\* @param r1 Number of rows in a

\* @param c1 Number of columns in a

\* @param r2 Number of rows in b

\* @param c2 Number of columns in b

\*/

void matrix\_sub(int\*\* a, int\*\* b, int r1, int c1, int r2, int c2)

{

int i,j,k,l;

int res[r1][c1];

if (r1 != r2 || c2 != c1)

{

char s[100];

char disp[]="Cannot be subtracted";

sprintf(s,"%s",disp);

writeString(s, sizeof(s));

}

else

{

for (i=0;i<r1;i++)

{

for(j=0;j<c1;j++)

{

res[i][j]= a[i][j] - b[i][j];

}

}

}

for (i=0;i<r1;i++)

{

for(j=0;j<c1;j++)

{

printf("res[%d][%d]= %d\n",i,j,res[i][j]);

char s[100];

sprintf(s,"%d,",res[i][j]);

writeString(s, strlen(s));

}}}

/\*\*

\* @brief Multiplies two matrices together

\*

\* @param a First matrix

\* @param b Second matrix

\* @param r1 Number of rows in a

\* @param c1 Number of columns in a

\* @param r2 Number of rows in b

\* @param c2 Number of columns in b

\*/

void matrix\_mul(int\*\* a, int\*\* b, int r1, int c1, int r2, int c2)

{

int i,j,k,l,m;

int res[r1][c2];

if(c1 != r2)

{

char s[100];

char disp[]="Cannot be multiplied";

sprintf(s,"%s",disp);

writeString(s, sizeof(s));

}

else

{

for (i=0;i<r1;i++)

{

for(j=0;j<c2;j++)

{

res[i][j]=0;

for(m=0;m<c1;m++)

{

res[i][j]=res[i][j]+ (a[i][m] \* b[m][j]);

}

}

}

}

for (i=0;i<r1;i++)

{

for(j=0;j<c2;j++)

{

printf("res[%d][%d]= %d",i,j,res[i][j]);

char s[100];

sprintf(s,"%d,",res[i][j]);

writeString(s, strlen(s));

}}}

/\*scalar multiplication\*/

void scalar\_matrix\_mul (int \*\*a, int r1, int c1)

{

int i,j;

int k;

int res[r1][c1];

for (i=0; i<r1; i++)

{

for (j=0;j<c1;j++)

{

res[i][j]=k\*a[i][j];

}

}

for (i=0;i<r1;i++)

{

for(j=0;j<c1;j++)

{

printf("res[%d][%d]= %d\n",i,j,res[i][j]);

char s[100];

sprintf(s,"%d,",res[i][j]);

writeString(s, strlen(s));

}}}

/\*\*

\* @brief Calculates determinant of a matrix

\*

\* @param a First matrix whose determinant is calculated

\* @param r1 Number of rows in a

\* @param c1 Number of columns in a

\*/

int matrix\_det(int\*\* a, int r1, int c1)

{

int D ;

int D1;

int n;

int \*\*temp;

int i,j=0;

int sign = 1;

// Base case : if matrix contains single element

if(r1!=c1)

{

//not possible to find determinant

char s[100];

char disp[]="Cannot find determinant";

sprintf(s,"%s",disp);

writeString(s, strlen(s));

}

else

{

n=r1;

if (n == 1)

{

D=a[0][0];

return(D);

}

else

{

D=0;

// Iterate for each element of first row

for (int f = 0; f < n; f++)

{

// Getting Cofactor of a[0][f]

temp= malloc(2\*sizeof\*temp);

for (i=0; i< n; i++)

{

temp[i]= malloc(2\*sizeof\*temp[i]);

}

i=0;

// Looping for each element of the matrix

for (int row = 0; row < n; row++)

{

for (int col = 0; col < n; col++)

{

// Copying into temporary matrix only those

// element which are not in given row and

// column

if (row != 0 && col != f)

{

temp[i][j++] = a[row][col];

// Row is filled, so increase row index and

// reset col index

if (j == n - 1)

{

j = 0;

i++;

}

}

}

}

if(f%2==0)

{

( D += a[0][f]

\*(matrix\_det(temp, n - 1,n - 1)));

}

else

{

D -= a[0][f]

\*(matrix\_det(temp, n - 1,n - 1));

}

// terms are to be added with alternate sign

D1=D;

}

}

}

return D1;}

/\*\*

\* @brief Calculates transpose of a matrix

\*

\* @param a is the matrix whose transpose is calculated

\* @param r1 Number of rows in a

\* @param c1 Number of columns in a

\*/

void matrix\_transpose(int \*\*a, int r1, int c1)

{

int i,j;

int res[r1][c1];

for (i=0; i<c1;i++)

{

for (j=0;j<r1;j++)

{

res[i][j]= a[j][i];

}

}

for (i=0;i<c1;i++)

{

for(j=0;j<r1;j++)

{

printf("res[%d][%d]= %d\n",i,j,res[i][j]);

char s[100];

sprintf(s,"%d,",res[i][j]);

writeString(s, strlen(s));

}}}

/\*......Main Program ........\*/

int main()

{

int ROW1, ROW2, COL1, COL2;

int \*\*A;

int \*\*B ;

int Determinant\_A,Determinant\_B;

int OP\_SEL;

char str[100];

int i,j,k;

printf("entered main\n");

//reading row and column size for matrix A and B

// Read the row, column size of matrix 1 and matrix 2 from the FPGA PIO layer.

ROW1= decode\_ascii();

COL1=decode\_ascii();

ROW2=decode\_ascii();

COL2=decode\_ascii();

//reading values into matrix A and B

//allocating memory

A= malloc(ROW1\*sizeof\*A);

for (i=0; i< ROW1; i++)

{

A[i]= malloc(COL1\*sizeof\*A[i]);

}

B= malloc(ROW2\*sizeof\*B);

for (i=0; i< ROW2; i++)

{

B[i]= malloc(COL2\*sizeof\*B[i]);

}

for (i=0;i<ROW1; i++)

{

for(j=0;j<COL1;j++)

{

A[i][j]=decode\_ascii();

}

}

for (i=0;i<ROW2; i++)

{

for(j=0;j<COL2;j++)

{

B[i][j]=decode\_ascii();

} }

printf("ROW1=%d\n",ROW1);

printf("COL1=%d\n",COL1);

printf("ROW2=%d\n",ROW2);

printf("COL2=%d\n",COL2);

//reading valaue that indicates type of operation

OP\_SEL=decode\_ascii();

printf("%d\n",OP\_SEL);

switch (OP\_SEL){

case 1:

writeString("Addition selected\r\n",strlen("Addition selected\r\n"));

matrix\_add(A,B,ROW1,COL1, ROW2,COL2);

break;

case 2:

writeString("Subtraction selected\r\n",strlen("Subtraction selected\r\n"));

matrix\_sub(A,B,ROW1,COL1, ROW2,COL2);

break;

case 3:

writeString("Multiplication selected\r\n",strlen("Multiplication selected\r\n"));

matrix\_mul(A,B,ROW1,COL1, ROW2,COL2);

break;

case 4:

writeString("Determinant selected\r\n",strlen("Determinant selected\r\n"));

Determinant\_A=matrix\_det(A,ROW1,COL1);

sprintf(str,"%d\r\n",Determinant\_A);

writeString(str, strlen(str));

Determinant\_B=matrix\_det(B,ROW2,COL2);

sprintf(str,"%d",Determinant\_B);

writeString(str, strlen(str));

break;

case 5:

matrix\_transpose(A,ROW1,COL1);

break;

default:

writeString(“default selected”, strlen(“default selected”));

break;

}

//deallocating memory

free(A);

free(B);

return 0;

}

*End of document*